

FIG. 1



FIG. 2



FIG. 3

 $\langle \Box \rangle$  high speed

←→ low speed



F1G. 4



F1G. 5



FIG. 6



FIG. 7



FIG. B





F1G. 11



FIG. 12



FIG. 13



FIG. 14



FIG. 15



FIG. 16





FIG. 18



FIG. 19





FIG. 22



FIG. 22







FIG. 26



FIG. 27



FIG. 28



FIG. 29



FIG. 30



FIG. 31



Transaction 1: Long packet to an addressed ISISlave



Transaction 2: Ping packet to an addressed ISISlave. ISISlave has nothing to send



Transaction 3: Ping packet to an addressed ISISlave. ISISlaveA responds with a long packet to ISISlaveB (or the ISIMaster) and ISISlaveB (or the ISIMaster) responds with an ACK or NAK.

FIG. 32



FIG. 33



FIG. 34



FIG. 35



FIG. 36



FIG. 37



FIG. 38



FIG. 39



FIG. 40



FIG. 41



FIG. 42



FIG. 43



FIG. 44



FIG. 45



FIG. 46



FIG. 47



FIG. 48



FIG. 49



FIG. 50



FIG. 51



FIG. 52



FIG. 54



FIG. 53



FIG. 55







FIG. 57



FIG. 58





F1G. 61



FIG. 62



Machine remains in same state by default All outputs are zero unless otherwise stated

State Description:

Normal Idle state : elbi Compare interrupt level. Determines the Compare:

interrupt source

Interrupt clear, clear the pending bit for the current interrupt vector IntClear:



FIG. 63A



FIG. 64

→ tim\_icu\_wd\_irq
→ tim\_cpr\_reset\_n

32

Counter Logic

8,

write\_data —

- uew\_gopw

Timer Decode

wdog\_tim\_thres

cnt\_en

wdog\_unit\_sel—

tim\_pulse[0] -tim\_pulse[1] -tim\_pulse[2] -- ■ wdog\_tim\_cnt



FIG. 66



FIG. 67



FIG. 68



FIG. 69





Note: All logic clocked on bufrefclk unless otherwise indicated

FIG. 72



FIG. 73



FIG. 74



FIG. 75





FIG. 77

S = Start condition
A = Ack
N = Nack
P = Stop condition
Shaded bits driven by slave Д Ы 4 Z Data(8) Byte M -- ▶ Data(8) A FIG. 78 ..... Data(8) ∢ Data(8) Byte 1 4 4 Data(8) Data(8) A A 0 D byte[7:1] ID byte[7:1]

Byte M

Byte M-1

N = Nack
P = Stop condition
Shaded bits driven by slave S = Start condition A = Ack

S

FIG. 79



FIG. 80



FIG. 81



FIG. 82



FIG. 83



FIG. 84



FIG. 85



FIG. 86



FIG. 201



F1G. 88



FIG. 89



FIG. 90



F1G. 91



FIG. 92



FIG. 93



FIG. 94



FIG. 95



FIG. 100



FIG. 96



FIG. 97



FIG. 98



FIG. 99



FIG. 101



FIG. 102



FIG. 103



FIG. 104



FIG. 105



FIG. 106



FIG. 107



FIG. 108



FIG. 109



FIG. 110

| CPU MMU logic delay CPU generates request Arbitration occurs | cycle 6 |
|--------------------------------------------------------------|---------|
| CPU captures<br>read data<br>in AHB bridge                   | cycle 5 |
| DRAM access (MSN2)                                           | cycle 4 |
| DRAM<br>access<br>(MSN1)<br>Tacc = 8 ns                      | cycle 3 |
| DCU Address<br>setup<br>cycle<br>(RST)                       | cycle 2 |
| CPU MMU logic delay CPU generates request Arbitration occurs | cycle 1 |

FIG. 11







FIG. 114





FIG. 116



FIG. 117



FIG. 118



FIG. 119



FIG. 120



FIG. 121



FIG. 122



FIG. 123



FIG. 124



FIG. 125



FIG. 126



FIG. 127



FIG. 128



FIG. 129



FIG. 130



FIG. 131



FIG. 132



FIG. 133

## State Machine A



FIG. 134

## **State Machine B**





FIG. 136



FIG. 137



FIG. 138



FIG. 139

## 121/331





FIG. 141



FIG. 142



FIG. 143



FIG. 144



FIG. 145



FIG. 146



FIG. 147



FIG. 148



FIG. 149



FIG. 150



FIG. 151



FIG. 152



FIG. 153



FIG. 154



FIG. 155



FIG. 156



FIG. 157



FIG. 158



FIG. 159



FIG. 160



FIG. 161



FIG. 162



FIG. 163



FIG. 164





FIG. 166



FIG. 167



FIG. 168



FIG. 169



FIG. 170



FIG. 171



FIG. 172



FIG. 173



FIG. 174



FIG. 175



FIG. 176



FIG. 177



FIG. 178



(a) Netpage tag background pattern



(b) Netpage tag showing data area

FIG. 179



FIG. 180



FIG. 181



FIG. 182



FIG. 183





| always 1     | always 1     | always 1     |  |  |  |  |  |
|--------------|--------------|--------------|--|--|--|--|--|
| (background) | (background) | (background) |  |  |  |  |  |
| data         | data         | data         |  |  |  |  |  |
| bit 0        | bit 1        | bit 2        |  |  |  |  |  |
| data         | data         | data         |  |  |  |  |  |
| bit 4        | bit 5        | bit 3        |  |  |  |  |  |

# FIG. 185

| L | .eg | je | na |
|---|-----|----|----|
| 1 |     | 7  |    |

| $\overline{}$ |            |
|---------------|------------|
|               | constant 0 |
|               | constant 1 |
| ю             | data bit 0 |
| b1            | data bit 1 |
| b2            | data bit 2 |
| b3            | data bit 3 |
| b4            | data bit 4 |
| b5            | data bit 5 |
|               |            |

| -  |    |            | ****       |    |            |            |            |    |    |            |    |            |    |    |    |    |    |            |    |    |
|----|----|------------|------------|----|------------|------------|------------|----|----|------------|----|------------|----|----|----|----|----|------------|----|----|
| _  | ю  | ю          | ю          | ю  | ю          |            |            | b1 | b1 | b1         | b1 | b1         |    | _  | b2 | b2 | b2 | b2         | b2 |    |
| ьо | bO | ю          | ю          | ю  | ю          | ю          | b1         | b1 | b1 | b1         | b1 | b1         | b1 | b2 | b2 | b2 | b2 | b2         | b2 | b2 |
| ю  | ьо | ю          | ьо         | ю  | ю          | ю          | b1         | b1 | b1 | b1         | b1 | b1         | b1 | b2 | b2 | b2 | b2 | b2         | b2 | b2 |
| ьо | ю  | ю          | ю          | ю  | ю          | ю          | <b>b1</b>  | b1 | ь1 | b1         | b1 | b1         | b1 | b2 | b2 | b2 | b2 | b2         | b2 | b2 |
| ю  | ьо | ю          | ю          | ю  | ю          | ю          | b1         | b1 | b1 | b1         | b1 | b1         | b1 | b2 | b2 | b2 | b2 | b2         | b2 | b2 |
| ьо | ьо | ю          | ю          | ю  | ю          | ю          | b1         | b1 | b1 | Ы1         | b1 | b1         | b1 | b2 | b2 | b2 | b2 | b2         | b2 | b2 |
|    | ьо | ю          | ю          | ю  | ю          |            |            | b1 | b1 | ь1         | þ1 | b1         |    |    | b2 | b2 | b2 | b2         | b2 |    |
|    | b4 | <b>b</b> 4 | <b>b</b> 4 | b4 | <b>b</b> 4 |            |            | b5 | b5 | b5         | b5 | b5         |    |    | ьз | b3 | ьз | ьз         | b3 |    |
| b4 | b4 | b4         | <b>b</b> 4 | b4 | b4         | <b>b</b> 4 | b5         | b5 | b5 | b5         | b5 | b5         | b5 | b3 | ьз | ьз | ьз | ьз         | ьз | ьз |
| b4 | b4 | b4         | b4         | b4 | <b>b</b> 4 | <b>b</b> 4 | b5         | b5 | b5 | b5         | b5 | b5         | b5 | ьз | ьз | ьз | ьз | ьз         | ьз | ьз |
| b4 | b4 | b4         | b4         | b4 | b4         | b4         | b5         | b5 | b5 | b5         | b5 | b5         | b5 | ьз | ьз | ьз | ьз | ьз         | ь3 | ьз |
| b4 | b4 | b4         | b4         | b4 | <b>b</b> 4 | b4         | <b>b</b> 5 | b5 | b5 | b5         | b5 | <b>b</b> 5 | b5 | ьз | ьз | ьз | ьз | ьз         | ьз | ьз |
| b4 | b4 | b4         | <b>b</b> 4 | b4 | b4         | <b>b</b> 4 | <b>b</b> 5 | b5 | b5 | b5         | b5 | b5         | b5 | ь3 | ьз | ь3 | ь3 | ьз         | ьз | ьз |
|    | b4 | b4         | b4         | b4 | b4         |            |            | b5 | b5 | <b>b</b> 5 | b5 | b5         |    |    | b3 | b3 | ьз | <b>b</b> 3 | b3 |    |

FIG. 186



FIG. 187



FIG. 188



FIG. 189



FIG. 191



FIG. 190



FIG. 192



FIG. 193



FIG. 194



FIG. 195



FIG. 196



FIG. 197

# **ENCODED TAG DATA INTERFACE**

-Encoded fixed data can be up to 120 bits long -Use 2 buffers to allow for 2 simultaneously

READs in one cycle.

-These stores hold the fixed tag data for 1 tag. -Total memory = 120x2 = 240 bits



READ

5 G

WRITE

RAW TAG DATA INTERFACE

8.64

Encoded variable data can be up to 360 bits long Use 2 buffers to allow for 2 simultaneously -Use 2 buffers to allow for simultaneously READ/WRITE READs in one cycle.

-Total memory = 380A2A2 = 1280 bits
-Min tag width = 126 dots so the fastest that 1 tag can be read = 1262 = 63 cycles

-The store uses 9-bit addressing. Bit-9 indicates which buffer.
-Once printing has started each half buffer has 1/2 a line in which to be loaded i.e. for a 12,8 inch line it has 10240 dots or 5120 cycles

for an 8 inch line it has 6400 dots or 3200 cycles

-Therefore the data will be updated at most every 1290240 cycles.

-Total memory = 164x2x64 = 20992-bits

 From the specification, we must be able to process 2 dots/cycle. Once all this data is loaded it will be valid for at least 126 lines.

-126 lines contains 20480x126 = 2580480 dots.

-Max memory needed for 1 line of tag data = 2x64x164 = 656x32

-max dots/line = 1600x12.8 = 20480 -max tags/line = 20480/126 = 163 -max variable data/tag = 120

-min dot/tag 126 (specified)

-Divide this in half to allow for simultaneous READ/WRITE





FIG. 200



FIG. 201





FIG. 203



FIG. 204



FIG. 205



FIG. 206



FIG. 207



FIG. 208





F16. 211



FIG. 212



FIG. 213



exclusive OR gate

FIG. 214



exclusive OR gate



FIG. 216



FIG. 217



FIG. 218



FIG. 219



FIG. 220



FIG. 221



FIG. 222



FIG. 223



FIG. 224



FIG. 225



FIG. 226



FIG. 227



TFU



FIG. 250



FIG. 231









FIG. 234



FIG. 235





FIG. 237

## 204/331



FIG. 238





FIG. 240







FIG. 242



FIG. 243

## 210/331



FIG. 244



FIG. 245



FIG. 246



FIG. 247



FIG. 248



FIG. 249



FIG. 250



FIG. 251





Note: Paper passes under printhead

FIG. 254



FIG. 255





non-printable area 1 = inverted non-printable area 2

FIG. 257

| printhead A | printhead B |
|-------------|-------------|
|             |             |
|             |             |
|             |             |



FIG. 259



FIG. 261



FIG. 262



FIG. 263









FIG. 268



M - Midway point in dots
N - Number of dots in a line

Note: Paper passing under printhead



FIG. 270





FIG. 272





FIG. 274







All outputs are zero unless otherwise stated Machine remains in same state by default

State Description:

Idle state wait for active request

ColorSelect: Select the color to update before requesting to DIU

Request issued wait for acknowledge

Request:

Data word 0 transfer Data word 1 transfer Data word 2 transfer

Data word 3 transfer





FIG. 279



M - Midway point in dots N - Number of dots in a line

Note: Paper passing under printhead

FIG. 280



FIG. 281



FIG. 282







FIG. 285











All outputs are zero unless otherwise stated Machine remains in same state by default

State Description:

Normal reset state Reset: Count the FrclkPre number of clock cycles, repeat count set to FrclkNum FirePre:

Count the FrclkHigh number of clock cycles FireHigh:

Count the FrclkLow number of clock cycles

FireLow:



FIG. 289



FIG. 290



Line end processing wait for both line\_fin to be active

Start processing first part of the line, wait for both mid\_pt to be active Switch over wait state allow pipeline to clear

Normal reset state

All outputs are zero unless otherwise stated Machine remains in same state by default

State Description:





State Description:

Normal reset state Reset:

Count the SrcikPre number of clock SrclkPre:

cycles

DataGen1: Read Line Dot data from buffer

DataGen2: Read Line Dot data from buffer

Data gen wait state DataGen3:

Data rate control wait state Wait1:

Data rate control wait state Data rate control wait state Wait3: Wait2:

MarginGen1:Generate DotMargin number of dots MarginGen2:Generate DotMargin number of dots

SrclkPost: Wait for SrclkPost number of cycles MarginGen3:Generate margin wait state





FIG. 293



FIG. 294



FIG. 295



FIG. 296



FIG. 297



FIG. 298



FIG. 299



FIG. 300



FIG. 301



FIG. 302



FIG. 303



FIG. 304



FIG. 305



FIG. 306



FIG. 307

| Pads | Nozzle Column | Nozzle Column | Nozzle Column | <br>Nozzle Column | Nozzle Column | Nozzle Column | Fire/Select Shift Register  Dot SR 5/Colour 5  Dot SR 4/Colour 4  Dot SR 3Colour 3  Dot SR 2/Colour 2  Dot SR 1/Colour 1  Dot SR 0/Colour 0 |
|------|---------------|---------------|---------------|-------------------|---------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------|
|      |               |               |               |                   |               |               | Dot SR 0/Colour 0                                                                                                                           |

FIG. 308



FIG. 309



FIG. 310



FIG. 311

|   | a) Printing every $n^{ m th}$ dot with all zero's in the fire select shift register | b) Printing every n <sup>th</sup> dot with all one's in the fire select shift register | c) Printing every $n^{th}$ dot with n zero's then n one's in the fire select shift registers |
|---|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| ) | a) Printing every                                                                   | b) Printing every                                                                      | c) Printing every                                                                            |

FIG. 312

FIG. 313

| 10000000100000000001000000000          | 1000000001000000000100000000        | 111111111100000000001111111111000000    | Right Print Head Fire/Select SR |
|----------------------------------------|-------------------------------------|-----------------------------------------|---------------------------------|
| - 000:000000100                        | 100000000010                        | 111111111100                            | Right Print Head                |
|                                        | <b>♣</b>                            |                                         |                                 |
|                                        | •                                   |                                         |                                 |
| 8                                      | 10                                  | 1                                       | Œ                               |
| 000                                    | 001                                 | 111                                     | sct SR                          |
| 000000001000000000                     | 000000010000000001                  | 000000001111111111                      | Print Head Fire/Select SR       |
| 00010000000001000000000                | 00100000000001000000000000000000000 | 111000000000000001111111111111111111111 | Left Print Head Fire/Select SR  |
| 00010000000001000000000                | 001000000000010000000               | 111000000000001111111                   | Left Print Head Fire/Select SR  |
| 10000000001000000000100000000001000000 | 000000000010000000000100000000      | 000000000011111111110000000000111111    | Left Print Head Fire/Select SR  |

FIG. 314



FIG. 315



FIG. 316



FIG. 317



FIG. 318





FIG. 320



FIG. 321



FIG. 322



FIG. 323



FIG. 324



dataset1 (supplied by QACo to Silverbrook for development only) dataset2 (generated by Silverbrook during development) Silverbrook program code (developmental) (could theoretically include additional public keys e.g. to test OEM code) Developmental Loader (checks for specific SoPECids) (includes Silverbrook Dev public key) signature (signed with asymmetric private boot0keys) length + SHA-1(Silverbrook\_program\_code) by QACo by Silverbrook Generated Generat d



FIG. 326



FIG. 328



FIG. 329



FIG. 330



FIG. 331



FIG. 332



FIG. 333



FIG. 334



FIG. 335



FIG. 336



FIG. 337



FIG. 338



FIG. 339



FIG. 340



FIG. 341



FIG. 342



FIG. 343



FIG. 344



FIG. 345



FIG. 346



FIG. 347



FIG. 348



FIG. 349



FIG. 350



FIG. 351



FIG. 352



FIG. 353



FIG. 354



FIG. 355



FIG. 356



FIG. 357



FIG. 358



FIG. 359



FIG. 360



FIG. 361



FIG. 362



FIG. 363

| 31 | 1                 | 7 16 |                          | 4 | 3 0                           |  |
|----|-------------------|------|--------------------------|---|-------------------------------|--|
|    | Type<br>(15 bits) |      | Permissions<br>(13 bits) |   | Size and Position<br>(4 bits) |  |

FIG. 364



FIG. 365

| 16       | 14 13     | 12      | 11       | 4 |
|----------|-----------|---------|----------|---|
| KeyNum   | NonAuthRW | AuthRW  | KeyPerms |   |
| (3 bits) | (1 bit)   | (1 bit) | (8 bits) |   |

FIG. 366



FIG. 367

| KeyNum | Non<br>AuthRW | AuthRW |   | KeyPerms |   |   |   |   |   |   |  |  |
|--------|---------------|--------|---|----------|---|---|---|---|---|---|--|--|
| 3      | 1             | 1      | 0 | 0        | 0 | 0 | 1 | 1 | 1 | 0 |  |  |

FIG. 368

| 3 | 17                | 16           | 14 | 13                       | 12                | 11 | 4                    | 3                  | _0 |
|---|-------------------|--------------|----|--------------------------|-------------------|----|----------------------|--------------------|----|
| ĺ | Type<br>(15 bits) | Keyl<br>(3 t |    | NonAuth<br>RW<br>(1 bit) | AuthRW<br>(1 bit) |    | KeyPerms<br>(8 bits) | EndPos<br>(4 bits) |    |

FIG. 369



FIG. 370



FIG. 371



FIG. 372



FIG. 373



FIG. 374



FIG. 375



FIG. 376



FIG. 377



FIG. 378



FIG. 379



FIG. 380



FIG. 381



FIG. 382



FIG. 383



FIG. 384



FIG. 385



FIG. 386



FIG. 387

| bit 31               | bit 0          |
|----------------------|----------------|
| preauth field select | preauth amount |
| = 8 bits             | = 24 bits      |

FIG. 388



FIG. 389



FIG. 390



FIG. 391



FIG. 392



FIG. 393



FIG. 394



FIG. 395

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0                         |
|--------|--------|--------|--------|--------|--------|--------|-------------------------------|
| PriID6 | PriID5 | PriID4 | PriID3 | PriID2 | PriID1 | PrilD0 | R/*W<br>0 = write<br>1 = read |

FIG. 396



FIG. 397



FIG. 398



FIG. 399



FIG. 400



FIG. 401



FIG. 402



FIG. 403



FIG. 404



FIG. 405



FIG. 406



FIG. 407



FIG. 408



FIG. 409



FIG. 410



FIG. 411



FIG. 412



FIG. 413